$(function () {
  const layer = layui.layer;
  // 1.1 获取裁剪区域的 DOM 元素
  const $image = $("#image");
  // 1.2 配置选项
  const options = {
    // 纵横比
    aspectRatio: 1,
    // 指定预览区域
    preview: ".img-preview"
  };

  // 1.3 创建裁剪区域
  $image.cropper(options);

  // 为上传按钮绑定点击事件 转换到file表单点击
  $("#btnUpload").on("click", function () {
    $("#file").click();
  });

  // 监测表单更改事件  只有当选择文件后会触发
  $("#file").on("change", function () {
    let file = $(this)[0].files[0];
    let imgUrl = URL.createObjectURL(file);
    $image
      .cropper("destroy") // 销毁旧的裁剪区域
      .attr("src", imgUrl) // 重新设置图片路径
      .cropper(options); // 重新初始化裁剪区域
  });

  // 为确定按钮绑定点击事件
  $("#btnOk").on("click", function () {
    let dataURL = $image
      .cropper("getCroppedCanvas", {
        // 创建一个 Canvas 画布
        width: 100,
        height: 100
      })
      .toDataURL("image/png"); // 将 Canvas 画布上的内容，转化为 base64 格式的字符串

    $.ajax({
      type: "POST",
      url: "/my/update/avatar",
      data: {
        avatar: dataURL
      },
      success: function (res) {
        if (res.status !== 0) return layer.msg(res.message);
        layer.msg(res.message);
        // 调用父页面的 获取用户信息函数  重新渲染页面
        parent.getUserInfo();
      }
    });
  });
});
